<link rel="stylesheet" href="/assets/home/css/coupon_list.css" />

<!-- 请求 -->
<script src="/assets/home/plugin/axios/axios.min.js"></script>
<script src="/assets/home/plugin/axios/request.js"></script>
<!-- 上拉刷新 -->
<link rel="stylesheet" href="/assets/home/plugin/mescroll/mescroll.min.css" />
<script src="/assets/home/plugin/mescroll/mescroll.min.js"></script>

<div id="couponlist" class="mescroll">
    <div class="coupon_list"></div>
</div>
<!-- 引入底部 -->
{include file='common/footer' /}

<script>

    // 页码
    let page = 1;

    var mescroll = new MeScroll("couponlist", { //第一个参数"mescroll"对应上面布局结构div的id
        //如果您的下拉刷新是重置列表数据,那么down完全可以不用配置,具体用法参考第一个基础案例
        down: {
            callback: downCallback //下拉刷新的回调,别写成downCallback(),多了括号就自动执行方法了
        },
        up: {
            callback: upCallback, //上拉加载的回调
            empty: {
                tip: "暂无相关数据~" //提示
            },
        }
    });

    //下拉刷新的回调
    function downCallback() {
        // 处理方式一: 重置mescroll内部变量(如mescroll.num=1和mescroll.hasNext=true), 自动触发upCallback
        mescroll.resetUpScroll();
        $("#couponlist .coupon_list").html('');
    }

    //上拉加载的回调 page = {num:1, size:10}; num:当前页 默认从1开始, size:每页数据条数,默认10
    async function upCallback(val) {
        page = val.num
        let result = await POST({
            url: `{:url('home/business/coupon')}`, params: {
                page: page,
            }
        });

        if (result.code == 0) {
            mui.toast(result.msg);
            mescroll.endBySize(0, 0);
            return false;
        }

        let list = result.data.list ?? [];
        let count = result.data.count ?? 0;

        //方法二(推荐): 后台接口有返回列表的总数据量 totalSize
        //必传参数(当前页的数据个数, 总数据量)
        mescroll.endBySize(list.length, count);

        getPageData(list)
    }

    // 处理数据
    function getPageData(list) {
        let html = '';
        for (let i = 0; i < list.length; i++) {
            let item = list[i];
            html += `
                    <div class="coupon_item">
                        <div class="item_content">
                            <a href="{:url('home/coupon/info')}?cid=${item.id}">
                                <div class="left">
                                    ${item.rate * 100}<span>折</span>
                                </div>
                                <div class="right">
                                    <div>${item.title}</div>
                                    <div>活动开始时间: ${item.createtime_text}</div>
                                    <div>活动结束时间: ${item.endtime_text}</div>
                                    <div>领取数量: ${item.total} 张 每人限领1张</div>
                                </div>
                            </a>
                        </div>
                        <div class="item_btn">
                            <a href="{:url('home/coupon/info')}?cid=${item.id}" class="mui-btn mui-btn-primary">查看详情</a>
                        </div>
                    </div>
                `;
        }
        $("#couponlist .coupon_list").append(html);
    }

    // 页面加载完成后, 自动触发一次上拉加载
    mescroll.upCallback();
</script>